Skip to content

Conversation

@tatha0003
Copy link

@tatha0003 tatha0003 commented Apr 23, 2024

Summary

Include a summary of major changes in bullet points:

  • Feature:
  • GW-BSE calculation with Abinit
  • GW workflow includes convergence tests for important parameters like the number of empty bands
  • BSE workflow has the option to choose model dielectric function or full screening matrix to use
  • BSE workflow includes convergence with respect to the number of k-points.

Additional dependencies introduced (if any)

No additional dependencies

TODO (if any)

Need to move /atomate2/abinit/sets/factories.py to abipy/abio/factories.py

@tatha0003 tatha0003 changed the title GW calculation with Abinit [WIP] GW-BSE calculation with Abinit Oct 12, 2024
Copy link
Contributor

@gpetretto gpetretto left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @tatha0003 for implementing this.
Here are my comments.

)
ab1 = load_abinit_input(prev_outputs[0])
if NSCF not in ab1.runlevel:
raise RuntimeError("Could not find one NSCF calculation.")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In principle all the checks above should be already be performed in the get_abinit_input in the base class, since the factory_prev_inputs_kwargs is set. This does provide more detailed error messages, but I would rather improve the errors provided by the base class, rather than overriding the method for all the subclasses. I think that all the implementation of this method can be removed, is that correct?

else:
raise RuntimeError("Could not find one NSCF and one SCREENING calculation.")

if nscf_inp.vars["ngkpt"]!=scr_inp.vars["ngkpt"]:
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As in the case of BSEmdfSetGenerator, also here most of the checks should be provided in the base class by the fact that factory_prev_inputs_kwargs is set.
This check on ngkpt is additional. I understand that this might be important, but is it really ngkpt the only value that would make the calculations incompatible? What if other keys as ecut or shiftk are different, just to mention a few?
If needed, I think this check can be performed in the factory, so the implementation of get_abinit_input could be removed entirely from here.

if factory_kwargs:
factory_kwargs.update({"ecutwfn": nscf_inp["ecut"]})
else:
factory_kwargs={"ecutwfn": nscf_inp["ecut"]}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can this be done in the factory? Or is it not strictly necessary in general?

)

class Config:
arbitrary_types_allowed = True
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why is this needed?

shifts=self.shifts,
chksymbreak=0)
)
nscf_job = update_user_abinit_settings(
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If there are several updates that need to be performed on the nscf input, could it be worth to define a specific input set?

return Flow(jobs, output=bse_job.output, name=self.name)

@job(name="Find BSE parameters")
def find_bse_params(self, bandlims, enwinbse, directgap):
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As for the other Flows, I think it would be better if the jobs are not methods of the Maker, aside from make. This could simply be a job function in jobs/bse.

# - check nbands in nscf is >= nband in screening and sigma
# pass

def make(
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can't this simply be a subclass of ConvergenceMaker redefining the default value that change (e.g. criterion_name, epsilon, ...)?


name: str = "BSE Mutiple Shifted Grid"
scf_maker: BaseAbinitMaker = field(default_factory=StaticMaker)
bse_maker: BaseAbinitMaker = field(default_factory=BSEFlowMaker)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As above, this is declared as a BaseAbinitMaker, but the default is a BSEFlowMaker. Should the type be just a Maker?

@VicTrqt VicTrqt mentioned this pull request Nov 19, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants